home *** CD-ROM | disk | FTP | other *** search
/ AmigActive 10 / AACD 10.iso / AACD / Online / SpeakFreely / src / blowfish / bf_locl.h < prev    next >
C/C++ Source or Header  |  2000-05-18  |  10KB  |  237 lines

  1. /* crypto/bf/bf_local.h */
  2. /* Copyright (C) 1995-1997 Eric Young (eay@mincom.oz.au)
  3.  * All rights reserved.
  4.  *
  5.  * This package is an SSL implementation written
  6.  * by Eric Young (eay@mincom.oz.au).
  7.  * The implementation was written so as to conform with Netscapes SSL.
  8.  * 
  9.  * This library is free for commercial and non-commercial use as long as
  10.  * the following conditions are aheared to.  The following conditions
  11.  * apply to all code found in this distribution, be it the RC4, RSA,
  12.  * lhash, DES, etc., code; not just the SSL code.  The SSL documentation
  13.  * included with this distribution is covered by the same copyright terms
  14.  * except that the holder is Tim Hudson (tjh@mincom.oz.au).
  15.  * 
  16.  * Copyright remains Eric Young's, and as such any Copyright notices in
  17.  * the code are not to be removed.
  18.  * If this package is used in a product, Eric Young should be given attribution
  19.  * as the author of the parts of the library used.
  20.  * This can be in the form of a textual message at program startup or
  21.  * in documentation (online or textual) provided with the package.
  22.  * 
  23.  * Redistribution and use in source and binary forms, with or without
  24.  * modification, are permitted provided that the following conditions
  25.  * are met:
  26.  * 1. Redistributions of source code must retain the copyright
  27.  *    notice, this list of conditions and the following disclaimer.
  28.  * 2. Redistributions in binary form must reproduce the above copyright
  29.  *    notice, this list of conditions and the following disclaimer in the
  30.  *    documentation and/or other materials provided with the distribution.
  31.  * 3. All advertising materials mentioning features or use of this software
  32.  *    must display the following acknowledgement:
  33.  *    "This product includes cryptographic software written by
  34.  *     Eric Young (eay@mincom.oz.au)"
  35.  *    The word 'cryptographic' can be left out if the rouines from the library
  36.  *    being used are not cryptographic related :-).
  37.  * 4. If you include any Windows specific code (or a derivative thereof) from 
  38.  *    the apps directory (application code) you must include an acknowledgement:
  39.  *    "This product includes software written by Tim Hudson (tjh@mincom.oz.au)"
  40.  * 
  41.  * THIS SOFTWARE IS PROVIDED BY ERIC YOUNG ``AS IS'' AND
  42.  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  43.  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
  44.  * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
  45.  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
  46.  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
  47.  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
  48.  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
  49.  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
  50.  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
  51.  * SUCH DAMAGE.
  52.  * 
  53.  * The licence and distribution terms for any publically available version or
  54.  * derivative of this code cannot be changed.  i.e. this code cannot simply be
  55.  * copied and put under another distribution licence
  56.  * [including the GNU Public Licence.]
  57.  */
  58. /* WARNING WARNING WARNING WARNING WARNING WARNING WARNING WARNING WARNING
  59.  *
  60.  * Always modify bf_locl.org since bf_locl.h is automatically generated from
  61.  * it during SSLeay configuration.
  62.  *
  63.  * WARNING WARNING WARNING WARNING WARNING WARNING WARNING WARNING WARNING
  64.  */
  65.  
  66. /*
  67.     Notwithstanding the above warning, bf_locl.h is *not* regenerated
  68.     in this stand-alone implementation.  The following auto-configuration
  69.     based on compiler CPU identification was added by John Walker to
  70.     avoid having to modify the Makefile to choose the best optimisation
  71.     for an individual platform.
  72. */
  73.  
  74. #ifdef sparc
  75. #define BF_PTR
  76. #endif
  77. #ifdef mips
  78. #define BF_PTR
  79. #endif
  80. /* In addition, for best performance we should define BF_PTR2 for
  81.    Pentium and below x86 machines, but not define it for Pentium
  82.    Pro and above.  I don't know of any compiler-independent way
  83.    to distinguish these platforms, so I'm leaving the optimisation
  84.    as best for the newer platforms.  The actual performance difference
  85.    for this application is trivial in any case. */
  86.  
  87. #undef c2l
  88. #define c2l(c,l)        (l =((unsigned long)(*((c)++)))    , \
  89.                          l|=((unsigned long)(*((c)++)))<< 8L, \
  90.                          l|=((unsigned long)(*((c)++)))<<16L, \
  91.                          l|=((unsigned long)(*((c)++)))<<24L)
  92.  
  93. /* NOTE - c is not incremented as per c2l */
  94. #undef c2ln
  95. #define c2ln(c,l1,l2,n) { \
  96.                         c+=n; \
  97.                         l1=l2=0; \
  98.                         switch (n) { \
  99.                         case 8: l2 =((unsigned long)(*(--(c))))<<24L; \
  100.                         case 7: l2|=((unsigned long)(*(--(c))))<<16L; \
  101.                         case 6: l2|=((unsigned long)(*(--(c))))<< 8L; \
  102.                         case 5: l2|=((unsigned long)(*(--(c))));     \
  103.                         case 4: l1 =((unsigned long)(*(--(c))))<<24L; \
  104.                         case 3: l1|=((unsigned long)(*(--(c))))<<16L; \
  105.                         case 2: l1|=((unsigned long)(*(--(c))))<< 8L; \
  106.                         case 1: l1|=((unsigned long)(*(--(c))));     \
  107.                                 } \
  108.                         }
  109.  
  110. #undef l2c
  111. #define l2c(l,c)        (*((c)++)=(unsigned char)(((l)     )&0xff), \
  112.                          *((c)++)=(unsigned char)(((l)>> 8L)&0xff), \
  113.                          *((c)++)=(unsigned char)(((l)>>16L)&0xff), \
  114.                          *((c)++)=(unsigned char)(((l)>>24L)&0xff))
  115.  
  116. /* NOTE - c is not incremented as per l2c */
  117. #undef l2cn
  118. #define l2cn(l1,l2,c,n) { \
  119.                         c+=n; \
  120.                         switch (n) { \
  121.                         case 8: *(--(c))=(unsigned char)(((l2)>>24L)&0xff); \
  122.                         case 7: *(--(c))=(unsigned char)(((l2)>>16L)&0xff); \
  123.                         case 6: *(--(c))=(unsigned char)(((l2)>> 8L)&0xff); \
  124.                         case 5: *(--(c))=(unsigned char)(((l2)     )&0xff); \
  125.                         case 4: *(--(c))=(unsigned char)(((l1)>>24L)&0xff); \
  126.                         case 3: *(--(c))=(unsigned char)(((l1)>>16L)&0xff); \
  127.                         case 2: *(--(c))=(unsigned char)(((l1)>> 8L)&0xff); \
  128.                         case 1: *(--(c))=(unsigned char)(((l1)     )&0xff); \
  129.                                 } \
  130.                         }
  131.  
  132. /* NOTE - c is not incremented as per n2l */
  133. #define n2ln(c,l1,l2,n) { \
  134.                         c+=n; \
  135.                         l1=l2=0; \
  136.                         switch (n) { \
  137.                         case 8: l2 =((unsigned long)(*(--(c))))    ; \
  138.                         case 7: l2|=((unsigned long)(*(--(c))))<< 8; \
  139.                         case 6: l2|=((unsigned long)(*(--(c))))<<16; \
  140.                         case 5: l2|=((unsigned long)(*(--(c))))<<24; \
  141.                         case 4: l1 =((unsigned long)(*(--(c))))    ; \
  142.                         case 3: l1|=((unsigned long)(*(--(c))))<< 8; \
  143.                         case 2: l1|=((unsigned long)(*(--(c))))<<16; \
  144.                         case 1: l1|=((unsigned long)(*(--(c))))<<24; \
  145.                                 } \
  146.                         }
  147.  
  148. /* NOTE - c is not incremented as per l2n */
  149. #define l2nn(l1,l2,c,n) { \
  150.                         c+=n; \
  151.                         switch (n) { \
  152.                         case 8: *(--(c))=(unsigned char)(((l2)    )&0xff); \
  153.                         case 7: *(--(c))=(unsigned char)(((l2)>> 8)&0xff); \
  154.                         case 6: *(--(c))=(unsigned char)(((l2)>>16)&0xff); \
  155.                         case 5: *(--(c))=(unsigned char)(((l2)>>24)&0xff); \
  156.                         case 4: *(--(c))=(unsigned char)(((l1)    )&0xff); \
  157.                         case 3: *(--(c))=(unsigned char)(((l1)>> 8)&0xff); \
  158.                         case 2: *(--(c))=(unsigned char)(((l1)>>16)&0xff); \
  159.                         case 1: *(--(c))=(unsigned char)(((l1)>>24)&0xff); \
  160.                                 } \
  161.                         }
  162.  
  163. #undef n2l
  164. #define n2l(c,l)        (l =((unsigned long)(*((c)++)))<<24L, \
  165.                          l|=((unsigned long)(*((c)++)))<<16L, \
  166.                          l|=((unsigned long)(*((c)++)))<< 8L, \
  167.                          l|=((unsigned long)(*((c)++))))
  168.  
  169. #undef l2n
  170. #define l2n(l,c)        (*((c)++)=(unsigned char)(((l)>>24L)&0xff), \
  171.                          *((c)++)=(unsigned char)(((l)>>16L)&0xff), \
  172.                          *((c)++)=(unsigned char)(((l)>> 8L)&0xff), \
  173.                          *((c)++)=(unsigned char)(((l)     )&0xff))
  174.  
  175. /* This is actually a big endian algorithm, the most significate byte
  176.  * is used to lookup array 0 */
  177.  
  178. /* use BF_PTR2 for intel boxes,
  179.  * BF_PTR for sparc and MIPS/SGI
  180.  * use nothing for Alpha and HP.
  181.  */
  182. #if !defined(BF_PTR) && !defined(BF_PTR2)
  183. #undef BF_PTR
  184. #endif
  185.  
  186. #define BF_M    0x3fc
  187. #define BF_0    22L
  188. #define BF_1    14L
  189. #define BF_2     6L
  190. #define BF_3     2L /* left shift */
  191.  
  192. #if defined(BF_PTR2)
  193.  
  194. /* This is basically a special pentium verson */
  195. #define BF_ENC(LL,R,S,P) \
  196.         { \
  197.         BF_LONG t,u,v; \
  198.         u=R>>BF_0; \
  199.         v=R>>BF_1; \
  200.         u&=BF_M; \
  201.         v&=BF_M; \
  202.         t=  *(BF_LONG *)((unsigned char *)&(S[  0])+u); \
  203.         u=R>>BF_2; \
  204.         t+= *(BF_LONG *)((unsigned char *)&(S[256])+v); \
  205.         v=R<<BF_3; \
  206.         u&=BF_M; \
  207.         v&=BF_M; \
  208.         t^= *(BF_LONG *)((unsigned char *)&(S[512])+u); \
  209.         LL^=P; \
  210.         t+= *(BF_LONG *)((unsigned char *)&(S[768])+v); \
  211.         LL^=t; \
  212.         }
  213.  
  214. #elif defined(BF_PTR)
  215.  
  216. /* This is normally very good */
  217.  
  218. #define BF_ENC(LL,R,S,P) \
  219.         LL^=P; \
  220.         LL^= (((*(BF_LONG *)((unsigned char *)&(S[  0])+((R>>BF_0)&BF_M))+ \
  221.                 *(BF_LONG *)((unsigned char *)&(S[256])+((R>>BF_1)&BF_M)))^ \
  222.                 *(BF_LONG *)((unsigned char *)&(S[512])+((R>>BF_2)&BF_M)))+ \
  223.                 *(BF_LONG *)((unsigned char *)&(S[768])+((R<<BF_3)&BF_M)));
  224. #else
  225.  
  226. /* This will always work, even on 64 bit machines and strangly enough,
  227.  * on the Alpha it is faster than the pointer versions (both 32 and 64
  228.  * versions of BF_LONG) */
  229.  
  230. #define BF_ENC(LL,R,S,P) \
  231.         LL^=P; \
  232.         LL^=((( S[        (R>>24L)      ] + \
  233.                 S[0x0100+((R>>16L)&0xff)])^ \
  234.                 S[0x0200+((R>> 8L)&0xff)])+ \
  235.                 S[0x0300+((R     )&0xff)])&0xffffffff;
  236. #endif
  237.